<template>
  <el-form ref="deptForm" :model="form" :rules="rules" label-width="120px">
    <el-form-item label="部门名称" prop="name">
      <el-input v-model="form.name" style="width:80%" placeholder="1-50个字符" />
    </el-form-item>
    <el-form-item label="部门编码" prop="code">
      <el-input v-model="form.code" style="width:80%" placeholder="1-50个字符" />
    </el-form-item>
    <el-form-item label="部门负责人" prop="manager">
      <el-select v-model="form.manager" style="width:80%" placeholder="请选择">
        <el-option
          v-for="item in employees"
          :key="item.id"
          :label="item.username"
          :value="item.username"
        />
      </el-select>
    </el-form-item>
    <el-form-item label="部门介绍" prop="introduce">
      <el-input v-model="form.introduce" style="width:80%" placeholder="1-300个字符" type="textarea" :rows="3" />
    </el-form-item>
    <el-form-item>
      <el-button type="primary" size="small" @click="hSubmit">确定</el-button>
      <el-button size="small" @click="hCancel">取消</el-button>
    </el-form-item>
  </el-form>
</template>

<script>
import { getEmployeeSimple } from '@/api/employees'
import { addDepartments } from '@/api/departments.js'
import { getDepartDetail } from '@/api/departments'
import { updateDepartments } from '@/api/departments'

export default {
  // 父传子
  props: {
    // 添加部门的id
    id: {
      type: String,
      required: true
    },
    // 编辑状态
    isEdit: {
      type: Boolean,
      required: true
    },
    originList: {
      type: Array,
      required: true
    }
  },
  data() {
    // 校验code
    // 如果重复，就验证不通过
    const validCode = (rule, value, callback) => {
      console.log('validCode....', value)
      let existCodeList = this.originList.map(item => item.code)
      if (this.isEdit) {
        // 把当前正在编辑的部门编号（this.id）排除在外
        console.log('现在是编辑状态，正在编辑的id是', this.id)
        // 过滤掉当前的部门, map得到部门编号列表
        existCodeList = this.originList.filter(item => item.id !== this.id).map(item => item.code)
      }
      console.log('existCodeList', existCodeList)
      // 2. 检查value 是否存在其中
      existCodeList.includes(value) ? callback(new Error('编码' + value + '已经存在'))
        : callback()
    }
    // 校验name
    const validName = (rule, value, callback) => {
      // 思路：被占用的名字是这个部门的子部门
      let existNameList = this.originList.filter(item => item.pid === this.id).map(item => item.name)
      console.log('validName.... , 当前被校验的名字是', value)
      // const existNameList = ['财务核算部', '薪资核算部']
      // 如果是编辑，则被占用的名字 = 兄弟-自己
      if (this.isEdit) {
        // 1. 找到当前被编辑的元素
        const dept = this.originList.find(item => item.id === this.id)
        // 2. 取出pid(它的父级是谁)
        const pid = dept.pid
        // 3. 过滤： 同一个父级，不包括自己； map： 只要需要名字
        existNameList = this.originList.filter(item => item.pid === pid && item.id !== this.id).map(item => item.name)
      }
      console.log('被占用的名字列表', existNameList)

      if (existNameList.includes(value)) {
        callback(new Error('名字' + value + '已经被占用了'))
      } else {
        callback()
      }
    }
    return {
      form: {
        name: '', // 部门名称
        code: '', // 部门编码
        manager: '', // 部门管理者
        introduce: '' // 部门介绍
      },
      // 保存员工信息
      employees: [],
      // 校验规则
      rules: {
        name: [
          { required: true, message: '部门名称不能为空', trigger: 'blur' },
          { min: 1, max: 50, message: '部门名称要求1-50个字符', trigger: 'blur' },
          { validator: validName, trigger: 'blur' }
        ],
        code: [
          { required: true, message: '部门编码不能为空', trigger: 'blur' },
          { min: 1, max: 50, message: '部门编码要求1-50个字符', trigger: 'blur' },
          { validator: validCode, trigger: 'blur' }
        ],
        manager: [
          { required: true, message: '部门负责人不能为空', trigger: 'blur' }
        ],
        introduce: [
          { required: true, message: '部门介绍不能为空', trigger: 'blur' },
          { min: 1, max: 300, message: '部门介绍要求1-300个字符', trigger: 'blur' }
        ]
      }
    }
  },
  created() {
    this.loadEmployee()
    this.loadDetail()
  },
  methods: {
    // 手动兜底验证
    onSubmit() {
      // 表单验证
      this.$refs.deptForm.validate((val) => {
        if (!val) return
        this.isEdit ? this.doEdit() : this.doAdd()
      })
    },
    // 获取员工信息
    async loadEmployee() {
      const { data: res } = await getEmployeeSimple()
      console.log('获取员工信息-->', res)
      this.employees = res
    },
    // 执行具体的添加动作
    async doAdd() {
      // 去获取pid： 当前要添加的部门所在的父级的id
      // 从props中获取
      // 1. 组装参数
      const params = { ...this.form, pid: this.id }
      console.log(params)
      // 2. 调用接口
      const rs = await addDepartments(params)
      console.log(rs)
      // 3. 通知父组件：关闭弹层，再次更新数据
      this.$emit('success')
    },
    // 编辑部门
    async doEdit() {
      try {
        await updateDepartments(this.form)
        this.$message({ type: 'success', message: '修改成功' })
        this.$emit('success')
      } catch (err) {
        console.log(err)
        this.$message({ type: 'error', message: err })
      }
    },
    // 确定
    hSubmit() {
      this.isEdit ? this.doEdit() : this.doAdd()
    },
    // 用户点击了取消
    hCancel() {
      // 重置表单数据
      this.$refs.deptForm.resetFields()
      // 通知父组件去关闭弹层
      this.$emit('close')
    },
    // 获取当前部门的详情
    async loadDetail() {
      if (this.isEdit) {
        // alert('现在是编辑，要去获取详情')
        const { data: res } = await getDepartDetail(this.id)
        console.log('现在是编辑，要去获取详情', res)
        this.form = res
      }
    },
    // 重置表单
    resetForm() {
      this.$refs.deptForm.resetFields()
      console.log('resetForm')
    }
  }
}
</script>
